// 创建用户相关的小仓库
import { defineStore } from "pinia";
// 引入接口
import { reqLogin, reqUserInfo, reqLogout } from "@/api/user";
import type { userInfoReponseData,loginResponseData,loginFormData } from "@/api/user/type";
// 引入数据类型
// import type { loginForm, loginResponseData } from "@/api/user/type";
import type { UserState } from "./types/type";
// 引入操作本地存储数据的工具方法
import { GET_TOKEN, SET_TOKEN, REMOVE_TOKEN } from "@/utils/token";
// 引入常量路由（常量路由）
import { constantRoute } from "@/router/routes";
// 创建用户小仓库
let useUserStore = defineStore("User", {
  // 小仓库存储数据地方
  state: (): UserState => {
    return {
      token: GET_TOKEN(), //用户唯一标识token
      menuRoutes: constantRoute, // 仓库存储生成菜单需要数组（路由）
      username: "lois",
      avatar: "",
    };
  },
  // 异步|逻辑的地方
  actions: {
    // 用户登录的方法
    async userLogin(data: loginFormData) {
      // 登录请求
      let result: loginResponseData = await reqLogin(data);
      console.log(result);
      //   登录成功：成功200->token
      // 登录请求：失败201->登录失败错误信息
      if (result.code == 200) {
        // pinia仓库存储一下token
        // 由于pinia|vuex存储数据其实是利用js对象
        this.token = result.data as string;
        // 本地存储持久化存储一份
        SET_TOKEN(result.data as string);
        // 能保证当前async函数返回一个成功的promise
        return "ok";
      } else {
        return Promise.reject(new Error(result.data));
      }
    },
    // 获取用户信息方法
    async userInfo() {
      // 获取用户信息进行存储仓库当中【用户头像、名字】
      let result:userInfoReponseData = await reqUserInfo();
      console.log(result);
      //   如果获取用户信息成功，存储一下用户信息
      if (result.code == 200) {
        this.username = result.data.name;
        this.avatar = result.data.avatar;
        return 'OK' 
      } else {
        return Promise.reject(new Error(result.message))
      }
    },
    //退出登录
    async userLogout() {
      //退出登录请求
      let result: any = await reqLogout();
      if (result.code == 200) {
        //目前没有mock接口:退出登录接口(通知服务器本地用户唯一标识失效)
        this.token = "";
        this.username = "";
        this.avatar = "";
        REMOVE_TOKEN();
        return "ok";
      } else {
        return Promise.reject(new Error(result.message));
      }
    },
  },

  getters: {},
});
// 对外暴露获取小仓库的方法
export default useUserStore;
